科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道巧用触发器对"SQL Server"进行数据备份

巧用触发器对"SQL Server"进行数据备份

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

本文中,笔者主要讲解了如何使用触发器来对SQL Server进行数据备份,详细内容请大家参考本文。

作者:赛迪网 韩丹 来源:天新网 2008年3月21日

关键字: 数据库 Mssql SQL SQL Server

  • 评论
  • 分享微博
  • 分享邮件

本文中,笔者主要讲解了如何使用触发器来对SQL Server进行数据备份,详细内容请大家参考下文:

1、建立测试数据表:

第一个用于插入数据:test3

另外一个作为备份:test3_bak

以下是的引用片段:

create table test3(id int primary key not null 
identity(1,1),uname varchar(20),uage int); 
create table test3_bak(id int primary key not 
null identity(1,1),bid int,uname varchar(20), 
uage int,active char(1));

2、编写备份用的触发器,只有更新或者是插入的时候才触发

以下是引用片段:

alter trigger test3_bak_insert_update 
on test3 
for insert,update 
as 
declare @id int 
declare @uname varchar(20) 
declare @uage int 
begin 
select @id=id,@uname=uname,@uage=uage from inserted 
if @id<>0 
begin 
update test3_bak set active='0' where bid=@id 
insert into test3_bak(bid,uname,uage,active) 
values(@id,@uname,@uage,'1') 
end 
end

3、测试数据:

以下是引用的片段:

insert into test3(uname,uage) values('FLB',20) 
insert into test3(uname,uage) values('FLB1',21) 
insert into test3(uname,uage) values('FLB2',22) 
update test3 set uage=100 where id=27 
delete from test3 where id=20

4、大家可以采用下面的查询追踪两个表的数据变化:

以下是引用的片段:

select * from test3 
select * from test3_bak
    • 评论
    • 分享微博
    • 分享邮件
    闂侇収鍠曞▎銏㈡媼閵忋倖顫�

    濠碘€冲€归悘澶愬箖閵娾晜濮滈悽顖涚摃閹烩晠宕氶崶鈺傜暠闁诡垰鍘栫花锛勬喆椤ゅ弧濡澘妫楅悡娆撳嫉閳ь剟寮0渚€鐛撻柛婵呮缁楀矂骞庨埀顒勫嫉椤栨瑤绻嗛柟顓у灲缁辨繈鏌囬敐鍕杽閻犱降鍨藉Σ鍕嚊閹跺鈧﹦绱旈幋鐐参楅柡鍫灦閸嬫牗绂掔捄铏规闁哄嫷鍨遍崑宥夋儍閸曨剚浠樺ù锝嗗▕閳ь剚鏌ㄧ欢鐐寸▕鐎b晝顏遍柕鍡嫹

    重磅专题
    往期文章
    最新文章